草庐IT

java - 执行后台任务——替代 AsyncTask?

全部标签

ruby-on-rails - 来自 Crontab 的 Rake 任务?

堆栈:Apache2rails2.3.8红帽Linuxruby企业版1.8.7在我的应用程序用户的crontab中获得了以下rake任务,这意味着每15分钟将记录拉入数据库表中:*/15****app_usercd/var/www/apps/my_app/current/&&rakething:do_stuffRAILS_ENV=production我可以在cron日志中看到cron守护进程正在运行这个任务,但是它应该将记录拉入的数据库表没有改变。当我在/var/www/apps/my_app/current目录中手动运行该任务时,该任务运行正常,没有出现错误,并按照我的预期将记录拉入

ruby-on-rails - 使用 rvm 在 rails 3 中进行 rake 任务和 cron

我正在尝试在Rails3.0.9(使用RVM)中使用crontab运行Rake任务,但它不起作用。但是当我在控制台中运行时它工作正常我的佣金任务namespace:alertdodesc"createsomeremindernotification"task:send_reminder=>:environmentdop"mytaskgoeshere----"endend我的定时任务*/1****cd/home/anu-karthik/Documents/billguru/&&/home/anu-karthik/.rvm/gems/ruby-1.9.2-p0/bin/rakealert:

ruby - 使用 Net::HTTP block 形式的 HTTPS 请求——这可能吗?

要在没有block形式的情况下执行Net::HTTPhttps请求,您可以这样做:...http=Net::HTTP.new(url.host,url.port)http.use_ssl=true...但是有没有办法告诉Net::HTTP在进行block形式时使用https?u=URI.parse(url)Net::HTTP.start(u.host,u.port)do|http|#ifIputhttp.use_ssl=truehere,rubycomplainsthatthiscan't#bedonebecuasethesesionhasalreadystartedresp=http

Ruby - 执行已过期

我有这样的ruby​​代码:begindoc=Nokogiri::HTML(open(url).read.strip)rescueException=>exlog.error"Error:#{ex}"end我得到的日志是:ERROR--:Error:executionexpired我想要block重新执行直到它成功。我该怎么做? 最佳答案 我会稍微扩展一下我的评论。您可以使用retry返回到begin:begindoc=Nokogiri::HTML(open(url).read.strip)rescueException=>exlo

ruby-on-rails - 如何让自定义 Rake 任务在 Sinatra 中运行?

*我想在我的Sinatra应用程序中运行一个自定义Rake任务,但我总是rake中止!不知道如何构建任务“问候”。这是用于测试目的的自定义Rake任务(greet.rake):task:greetdoputs"Hello!"end我已将greet.rake放在./lib/tasks(Rails)中。我猜Rake找不到文件的正确目录。如何让自定义Rake任务在Sinatra中运行?我正在使用Ruby2.0.0和Sinatra1.4.4。更新Rakefile现在看起来像这样:require"./app"require"sinatra/activerecord/rake"require"./

ruby-on-rails - 如何获取 ActiveRecord 在 Ruby on Rails 中执行的最后一个 SQL 查询?

我正在寻找类似CodeIgniter的东西:$this->db->last_query();(http://codeigniter.com/user_guide/database/helpers.html) 最佳答案 据我所知,访问查询列表并不容易。尽管如此,您还是可以轻松访问它们,创建一个super简单的记录器。如果您打开ActiveRecord::ConnectionAdapters::AbstractAdapter类,您将看到一个名为log的方法。在每个查询上调用此方法以记录语句。默认情况下,它使用Rails记录器记录所有语句

ruby - 在控制台执行命令后避免打印

我正在打开非常大的YAML文件。这需要一段时间。但在打开它之后,它正在打印所有内容-并且它花费了很多倍的时间。那么如何避免在Ruby控制台中打印结果:data=YAML.load_file(...)#some1GBdatafile. 最佳答案 我假设您是在控制台中执行此操作。如果我不想看到输出,我通常只添加“;:ok”。data=YAML.load_file(...);:ok 关于ruby-在控制台执行命令后避免打印,我们在StackOverflow上找到一个类似的问题:

ruby - 使用当前本地用户 RVM 安装的可执行 Ruby 脚本?

我想要标题为#!的ruby​​脚本/usr/bin/ruby使用当前使用的rvm版本的ruby​​执行。我遇到了我使用给定版本但在执行脚本时调用系统ruby​​的问题。为系统上的每个用户安装RVM不是一种选择。问题:ruby-vruby1.9.3p0(2011-10-30revision33570)[x86_64-darwin11.3.0]/usr/bin/ruby-vruby1.8.7(2010-01-10patchlevel249)[universal-darwin11.0]如何在不执行系统范围的RVM安装的情况下实现以下目标?ruby-vruby1.9.3p0(2011-10-3

ruby-on-rails - 启动 irb 或脚本/控制台时未执行 ~/.irbrc

这是我尝试过的:1.geminstallawesome_print2.echo"require'ap'">>~/.irbrc3.chmodu+x~/.irbrc4.script/console5.ap{:test=>'value'}结果:NameError:undefinedlocalvariableormethod`ap'for# 最佳答案 要检查.irbrc中的错误,只需将.irbrc作为普通Ruby脚本(ruby~/.irbrc)执行,Ruby会告诉您哪一行失败。它可能会提示缺少IRB模块,只需要在脚本中使用'irb'(你只在

ruby - 有没有比 Ruby 的 Dir.glob 更快的替代品?

我正在使用Dir.glob访问与通配符模式匹配的所有文件的集合。Dir.glob('**/*.txt'){|file_name|parsefile_name}因为这个glob调用是递归的,并且因为涉及很多文件,所以glob在block开始之前需要很长时间来构建文件数组。我想要的是一种访问所有相同文件的方法,但在Ruby“发现”每个文件后立即调用block,以便立即处理第一个文件,而不是等待整个目录树完成搜索。有这样的构造吗? 最佳答案 您还可以使用find和IO.popenIO.popen("find.-name'*.txt'").